package com.thlws.sort;

/**
 * 选择出数组中的最小元素，将它与数组的第一个元素交换位置。
 * 再从剩下的元素中选择出最小的元素，将它与数组的第二个元素交换位置。
 * 不断进行这样的操作，直到将整个数组排序。
 * Created by  HanleyTang on 2019-01-02
 */
public class Selection {

    public static void main(String[] args) {

        int arr[] = {4,1,3,2};

        println(arr);

        for (int i = 0; i < arr.length; i++) {
            // 寻找[i, n)区间里的最小值的索引
            int minIndex = i;
            for (int j = i + 1; j < arr.length; j++) {
                if(arr[minIndex] > arr[j]){
                    minIndex = j;
                }
            }
            swap( arr , i , minIndex);
        }

        println(arr);
    }

    private static void swap(int[] arr, int i, int j) {
        int t = arr[i];
        arr[i] = arr[j];
        arr[j] = t;
    }

    private static void println(int arr[]){
        System.out.println();
        for (int a:arr) {
            System.out.print(a);
        }
    }

}
